package cn.iocoder.yudao.module.alipay.service.surname;

import java.util.*;
import javax.validation.*;
import cn.iocoder.yudao.module.alipay.controller.admin.surname.vo.*;
import cn.iocoder.yudao.module.alipay.dal.dataobject.sensitivenems.SensitiveNemsDO;
import cn.iocoder.yudao.module.alipay.dal.dataobject.surname.SurnameDO;
import cn.iocoder.yudao.framework.common.pojo.PageResult;

/**
 * 姓氏 Service 接口
 *
 * @author 芋道源码
 */
public interface SurnameService {

    /**
     * 创建姓氏
     *
     * @param createReqVO 创建信息
     * @return 编号
     */
    Long createSurname(@Valid SurnameCreateReqVO createReqVO);

    /**
     * 更新姓氏
     *
     * @param updateReqVO 更新信息
     */
    void updateSurname(@Valid SurnameUpdateReqVO updateReqVO);

    /**
     * 删除姓氏
     *
     * @param id 编号
     */
    void deleteSurname(Long id);

    /**
     * 获得姓氏
     *
     * @param id 编号
     * @return 姓氏
     */
    SurnameDO getSurname(Long id);

    /**
     * 获得姓氏列表
     *
     * @param ids 编号
     * @return 姓氏列表
     */
    List<SurnameDO> getSurnameList(Collection<Long> ids);

    /**
     * 获得姓氏分页
     *
     * @param pageReqVO 分页查询
     * @return 姓氏分页
     */
    PageResult<SurnameDO> getSurnamePage(SurnamePageReqVO pageReqVO);

    /**
     * 获得姓氏列表, 用于 Excel 导出
     *
     * @param exportReqVO 查询条件
     * @return 姓氏列表
     */
    List<SurnameDO> getSurnameList(SurnameExportReqVO exportReqVO);

    SurnameDO getByName(String name);

    SensitiveNemsDO validCellValue(String cellValue);
}
